

I2C Encoder

# **Revision History**

| Revision | Date     | Author(s) | Description                                             |  |  |  |
|----------|----------|-----------|---------------------------------------------------------|--|--|--|
| 1.0      | 28.07.17 | Simone    | Initial version                                         |  |  |  |
| 1.1      | 07.10.17 | Atika     | Review                                                  |  |  |  |
| 1.2      | 19.10.17 | Simone    | Added new image and detailed description of the jumpers |  |  |  |

# **Contents**

| 1 | Dev  | ce Overview                 | 3  |
|---|------|-----------------------------|----|
|   | 1.1  | Electrical characteristics  | 4  |
|   | 1.2  | Connection                  | 4  |
|   | 1.3  | $I^2C$ interface            | 5  |
| 2 | Reg  | sters                       | 6  |
|   | 2.1  | Configuration               | 6  |
|   |      | 2.1.1 General Configuration | 6  |
|   | 2.2  | Status                      | 7  |
|   | 2.3  | Counter Value               | 8  |
|   |      | 2.3.1 Counter Value         | 8  |
|   |      | 2.3.2 Counter Max           | 8  |
|   |      | 2.3.3 Counter Min           | 9  |
|   | 2.4  | LEDs                        | 9  |
|   |      | 2.4.1 LED A intensity       | 9  |
|   |      | 2.4.2 LED B intensity       |    |
| 3 | Scho | ematic 1                    | 10 |

## 1. Device Overview

The I2C Encoder is a small board where you can use a classical mechanical encoder with a  $I^2C$  bus. The device include also the possibility to add a bi-color LED and set luminosity trough the  $I^2C$  bus. It's possible to connect up to 16 boards in cascade and read all of them with the same  $I^2C$  bus.

The I2C Encoder have a series of 8 bit register where it is possible to configure the parameters and three 32 bit of register. The 32 bit registers are the most important because they store the counter value and the maximum and minimum threshold. Every time when the encoder is moved at least one step, the counter value is increased or decreased according to the rotation direction. When the counter value is outside of the limit set by the threshold, the counter value can be wrapped or can stuck on the threshold valued reached.

The I2C Encoder also has an open-drain interrupt pin. It is set to logic low every time when the encoder is rotated or pushed. The status register must be read by the master to check what is changed.



Figure 1.1: Top view of the board



Figure 1.2: Bottom view of the board



Figure 1.3: Dimensions of the board

#### 1.1 Electrical characteristics

| Parameter                              | Symbol           | Min                   | Max                   |
|----------------------------------------|------------------|-----------------------|-----------------------|
| Supply voltage                         | $V_{DD}$         | 2.5V                  | 5V                    |
| I <sup>2</sup> C input-low level       | V <sub>IL</sub>  | 0                     | 0.3 * V <sub>DD</sub> |
| I <sup>2</sup> C input-high level      | V <sub>IH</sub>  | 0.8 * V <sub>DD</sub> | $V_{DD}$              |
| I <sup>2</sup> C clock input frequency | f <sub>SCL</sub> |                       | 400kHz                |
| LED output current                     | I <sub>LED</sub> |                       | 30mA                  |
| Supply current (LEDs off)              | I <sub>DD</sub>  |                       | 1.8mA                 |
| I <sup>2</sup> C pull-up resistor      | $R_{I^2C}$       |                       | 4.7k $Ω$              |
| Interrupt pull-up resistor             | R <sub>INT</sub> | 15k $\Omega$          | 120k $Ω$              |

### 1.2 Connection

Figure 1.4 shows the pin out of the I2C Encoder.



Figure 1.4: Pin-out of the board

| Pin   | I/O Type | Function                    |  |  |  |  |
|-------|----------|-----------------------------|--|--|--|--|
| GND   | Power    | Ground reference for logic  |  |  |  |  |
| Vcc   | Power    | Positive supply for logic   |  |  |  |  |
| SDA   | I/O      | I <sup>2</sup> C data       |  |  |  |  |
| SCL I |          | I <sup>2</sup> C clock      |  |  |  |  |
| INT   | OD       | Open-drain interrupt output |  |  |  |  |

There are two 5 pin headers one the right and one at the left side of the I2C Encoder. The I2C Encoder can be connected in cascade as showed in figure 1.5, the maxim number of device is 16 due to the limitation of the  $I^2C$  address. Since the INT pin is open drain, the signal is propagated along the chain in case of interrupt of one device. In order to avoid  $I^2C$  address conflict, the address of each device must be different. In the section 1.3, it is described how to set the address.



Figure 1.5: Example of 4 boards connected in cascade

### 1.3 I<sup>2</sup>C interface

The I2C Encoder is a  $I^2C$  slave, it's possible to the set 16 different addresses. The last four LSB of the 7-bit address can be customized by soldering the jumpers A0 - A3 on the bottom of the board. When the jumper is open, it means a logic 0. if jumper is shorted it means a logic 1.

|   | I <sup>2</sup> C address |   |    |    |    |    |     |  |  |  |  |  |  |
|---|--------------------------|---|----|----|----|----|-----|--|--|--|--|--|--|
| 7 | 7 6 5 4 3 2 1 0          |   |    |    |    |    |     |  |  |  |  |  |  |
| 0 | 1                        | 1 | А3 | A2 | A1 | A0 | R/W |  |  |  |  |  |  |



Figure 1.6: Example of the address setting of the board in figure 1.5

The I2C Encoder has the  $I^2C$  pull-up resistors. By default, these resistors are not enabled. They can be enabled by soldering the jumper **P-UP** like in the figure 1.7. This must be done in case of the master doesn't have these resistors and must be enabled only one I2C Encoder in a chain.



Figure 1.7: Jumper P-UP soldered for enable the I<sup>2</sup>C resistors

# 2. Registers

In this section, the internal registers of I2C Encoder is described.

| Address | Description           | Default value |
|---------|-----------------------|---------------|
| 0×00    | General Configuration | 0×00          |
| 0×01    | Status                | 0×00          |
| 0×02    | Counter Value Byte 4  | 0×00          |
| 0×03    | Counter Value Byte 3  | 0×00          |
| 0×04    | Counter Value Byte 2  | 0×00          |
| 0×05    | Counter Value Byte 1  | 0×00          |
| 0×06    | Counter Max Byte 4    | 0×00          |
| 0×07    | Counter Max Byte 3    | 0×00          |
| 0×08    | Counter Max Byte 2    | 0×00          |
| 0×09    | Counter Max Byte 1    | 0×00          |
| 0×0A    | Counter Min Byte 4    | 0×00          |
| 0x0B    | Counter Min Byte 3    | 0×00          |
| 0x0C    | Counter Min Byte 2    | 0×00          |
| 0x0D    | Counter Min Byte 1    | 0×00          |
| 0×0E    | LED A intensity       | 0×00          |
| 0×0F    | LED B intensity       | 0×00          |

## 2.1 Configuration

### 2.1.1 General Configuration

| Address: 0x00   |   |       |       |       |       |       |       |  |  |  |  |
|-----------------|---|-------|-------|-------|-------|-------|-------|--|--|--|--|
| 7 6 5 4 3 2 1 0 |   |       |       |       |       |       |       |  |  |  |  |
| R/W-0           | - | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |  |  |  |  |
| RESET           | - | RMOD  | IPUD  | DIRE  | WRAPE | LEDE  | INTE  |  |  |  |  |

INTE Enable interrupt pin.

1: Enable

0: Disable

**LEDE** Enable LED output.

1: Enable

0: Disable

WRAPE Enable counter wrap.

1: Wrap enable. When the counter value reaches the  ${\bf CMAX}+1$ , restart to the  ${\bf CMIN}$  and vice versa

0: Wrap disable. When the counter value reaches the **CMAX** or **CMIN**, the counter stops to increasing or decreasing

**DIRE** Direction of the encoder when increment.

1: Rotate left side to increase the value counter

0: Rotate right side to increase the value counter

IPUD Interrupt Pull-UP disable.

1: Disable

0: Enable

RMOD Reading Mode.

1: X2 mode

0: X1 mode

RST Reset of the I2C Encoder

1: Reset

0: No reset

#### 2.2 Status

| Address: 0x01 |   |   |       |       |       |       |       |  |  |  |  |
|---------------|---|---|-------|-------|-------|-------|-------|--|--|--|--|
| 7             | 6 | 5 | 4     | 3     | 2     | 1     | 0     |  |  |  |  |
| -             | - | - | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |  |  |  |  |
| _             | - | - | RMIN  | RMAX  | RDEC  | RINC  | PUSH  |  |  |  |  |

**PUSH** Status of the push button of the encoder

1: Push button is pressed

0: Push button is not pressed

RINC Status of the counter value

1: Counter value is increased

0: Counter value is not increased

RDEC Status of the counter value

1: Counter value is decreased

0: Counter value is not decreased

RMAX Status of the counter value

 $1: \ \textbf{CVAL} \ \text{reaches the } \ \textbf{CMAX} \ \text{value}$ 

0: CVAL is below the CMAX value

RMIN Status of the counter value

1: CVAL reaches the CMIN value

0: CVAL is above the CMIN value

### 2.3 Counter Value

#### 2.3.1 Counter Value

| Address: 0x02 |       |       |           |                         |       |       |       |  |  |
|---------------|-------|-------|-----------|-------------------------|-------|-------|-------|--|--|
| 31            | 30    | 29    | 28        | 27                      | 26    | 25    | 24    |  |  |
| R/W-0         | R/W-0 | R/W-0 | R/W-0     | R/W-0                   | R/W-0 | R/W-0 | R/W-0 |  |  |
|               |       |       | CVAL BYTE | 4 <31 - 24>             |       |       |       |  |  |
|               |       |       | Address   | s: 0x03                 |       |       |       |  |  |
| 23            | 22    | 21    | 20        | 19                      | 18    | 17    | 16    |  |  |
| R/W-0         | R/W-0 | R/W-0 | R/W-0     | R/W-0                   | R/W-0 | R/W-0 | R/W-0 |  |  |
|               |       |       | CVAL BYTE | 3 <23 - 16>             |       |       |       |  |  |
|               |       |       | Address   | s: 0x04                 |       |       |       |  |  |
| 15            | 14    | 13    | 12        | 11                      | 10    | 9     | 8     |  |  |
| R/W-0         | R/W-0 | R/W-0 | R/W-0     | R/W-0                   | R/W-0 | R/W-0 | R/W-0 |  |  |
|               |       |       | CVAL BYTE | 2 <15 - 8>              |       |       |       |  |  |
|               |       |       | Address   | s: <b>0</b> x <b>05</b> |       |       |       |  |  |
| 7             | 6     | 5     | 4         | 3                       | 2     | 1     | 0     |  |  |
| R/W-0         | R/W-0 | R/W-0 | R/W-0     | R/W-0                   | R/W-0 | R/W-0 | R/W-0 |  |  |
|               |       |       | CVAL BYTE | = 1 <7 - 0>             |       |       |       |  |  |

This is a signed 32 bit register where the counter value is stored. When the encoder is rotated, the value is increased or decreased according to the direction.

#### 2.3.2 Counter Max

| Address: 0x06 |       |       |           |                         |       |       |       |  |  |
|---------------|-------|-------|-----------|-------------------------|-------|-------|-------|--|--|
| 31            | 30    | 29    | 28        | 27                      | 26    | 25    | 24    |  |  |
| R/W-0         | R/W-0 | R/W-0 | R/W-0     | R/W-0                   | R/W-0 | R/W-0 | R/W-0 |  |  |
|               |       | (     | CMAX BYTE | 4 < 31 - 24 >           | >     |       |       |  |  |
|               |       |       | Address   | s: <b>0</b> x <b>07</b> |       |       |       |  |  |
| 23            | 22    | 21    | 20        | 19                      | 18    | 17    | 16    |  |  |
| R/W-0         | R/W-0 | R/W-0 | R/W-0     | R/W-0                   | R/W-0 | R/W-0 | R/W-0 |  |  |
|               |       | (     | CMAX BYTE | 3 <23 - 16>             | >     |       |       |  |  |
|               |       |       | Address   | s: 0x08                 |       |       |       |  |  |
| 15            | 14    | 13    | 12        | 11                      | 10    | 9     | 8     |  |  |
| R/W-0         | R/W-0 | R/W-0 | R/W-0     | R/W-0                   | R/W-0 | R/W-0 | R/W-0 |  |  |
|               |       |       | CMAX BYTE | = 2 <15 - 8>            |       |       |       |  |  |
|               |       |       | Address   | s: <b>0</b> x <b>09</b> |       |       |       |  |  |
| 7             | 6     | 5     | 4         | 3                       | 2     | 1     | 0     |  |  |
| R/W-0         | R/W-0 | R/W-0 | R/W-0     | R/W-0                   | R/W-0 | R/W-0 | R/W-0 |  |  |
|               |       | -     | CMAX BYT  | E 1 <7 - 0>             | -     |       |       |  |  |

This is a signed 32 bit register, it is used for storing the maximum threshold of the **CVAL** register. When **CVAL** is greater than **CMAX**, the value of **CVAL** is set according the the flag **WRAPE**.

#### 2.3.3 Counter Min

| Address: 0x0A |       |       |           |             |       |       |       |  |  |
|---------------|-------|-------|-----------|-------------|-------|-------|-------|--|--|
| 31            | 30    | 29    | 28        | 27          | 26    | 25    | 24    |  |  |
| R/W-0         | R/W-0 | R/W-0 | R/W-0     | R/W-0       | R/W-0 | R/W-0 | R/W-0 |  |  |
|               |       |       | CMIN BYTE | 4 <15 - 8>  |       |       |       |  |  |
|               |       |       | Address   | :: 0x0B     |       |       |       |  |  |
| 23            | 22    | 21    | 20        | 19          | 18    | 17    | 16    |  |  |
| R/W-0         | R/W-0 | R/W-0 | R/W-0     | R/W-0       | R/W-0 | R/W-0 | R/W-0 |  |  |
|               |       |       | CMIN BYTE | E 3 <7 - 0> |       |       |       |  |  |
|               |       |       | Address   | : 0x0C      |       |       |       |  |  |
| 15            | 14    | 13    | 12        | 11          | 10    | 9     | 8     |  |  |
| R/W-0         | R/W-0 | R/W-0 | R/W-0     | R/W-0       | R/W-0 | R/W-0 | R/W-0 |  |  |
|               |       |       | CMIN BYTE | 2 <15 - 8>  |       |       |       |  |  |
|               |       |       | Address   | : 0x0D      |       |       |       |  |  |
| 7             | 6     | 5     | 4         | 3           | 2     | 1     | 0     |  |  |
| R/W-0         | R/W-0 | R/W-0 | R/W-0     | R/W-0       | R/W-0 | R/W-0 | R/W-0 |  |  |
|               |       |       | CMIN BYTI | E 1 <7 - 0> |       |       |       |  |  |

This is a signed 32 bit register, it is used for storing the minimum threshold of the **CVAL** register. When **CVAL** is less than **CMIN**, the value of **CVAL** is set according the the flag **WRAPE**.

#### **2.4 LEDs**

#### 2.4.1 LED A intensity

|       | Address: 0x0E                             |   |          |              |   |  |  |  |  |  |  |  |
|-------|-------------------------------------------|---|----------|--------------|---|--|--|--|--|--|--|--|
| 7     | 7 6 5 4 3 2 1 0                           |   |          |              |   |  |  |  |  |  |  |  |
| R/W-0 | R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 |   |          |              |   |  |  |  |  |  |  |  |
|       |                                           | L | ED A PWM | Value <7 - 0 | > |  |  |  |  |  |  |  |

This register is used for setting the PWM of the **LED A**, where the value of 0x00 means PWM at 0% and a value of 0xFF means PWM at 100%.

#### 2.4.2 LED B intensity

| Address: 0x0F           |       |       |       |       |       |       |       |
|-------------------------|-------|-------|-------|-------|-------|-------|-------|
| 7                       | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| R/W-0                   | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
| LED B PWM Value <7 - 0> |       |       |       |       |       |       |       |

This register is used for setting the PWM of the **LED B**. A value of 0x00 means PWM at 0% and a value of 0xFF means PWM at 100%

# 3. Schematic

